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Response to Amendment 

1. This action is responsive to amendment received on Oct. 7, 2004. Claims 2, 3 t 5, 
7, 10, 13, 15-17, 20, 22, 23, 26, 28, 31 and 34 were amended. Claims 4, 6, 8, 27 and 29 
were canceled. Claims 1-3, 5, 7, 9-26, 28 and 30-34 are pending examination. 

Claim Rejections - 35 USC § 102 
The following is a quotation of the appropriate paragraphs of 35 U.S.C. 102 that 
form the basis for the rejections under this section made in this Office action: 
A person shall be entitled to a patent unless - 

(e) the invention was described in (1 ) an application for patent, published under section 122(b), by 
another filed in the United States before the invention by the applicant for patent or (2) a patent 
granted on an application for patent by another filed in the United States before the invention by the 
applicant for patent, except that an international application filed under the treaty defined in section 
351(a) shall have the effects for purposes of this subsection of an application filed in the United States 
only if the international application designated the United States and was published under Article 21(2) 
of such treaty in the English language. 

2. Claims 1, 14,21 and 22 are rejected under 35 U.S.C. 102(e) as being anticipated 
by Wahl et al., U.S. Patent No. 6,618,818 (referred to hereafter as Wahl). 

Wahl teaches the invention explicitly as claimed including a system and method 
for enabling a user to create and configure throttles, which are user-defined tests and 
actions evaluated by the primary mirror daemon to regulate network bandwidth, CPU, 
and writelog device utilization (see abstract). 

As to claim 1 , Wahl teaches a method for correlating the execution throttle levels 
of the servers of a network to the command queue depth of the storage controllers in 
the network, each of the storage controllers managing one or more logical storage units, 
comprising the steps of: 
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identifying the servers of the network (see col. 13 lines 25-50, system identifies 
the servers of the network as being primary or secondary); 

identifying the logical ownership of each logical storage unit on the network (see 
col. 13 lines 25-50, system identifies the logical storage units connected to each server); 

verifying that a rule governing the command throughput of the servers and 
storage controllers of the network is satisfied, the rule defining a relation between the 
execution throttle levels of the servers of the network and command queue depth of the 
storage controllers of the network (see col. 16 lines 1-17, user enters a server throttle 
value to b compared to queue value); and 

adjusting the execution throttle level of at least one server of the network in 
response to a determination that the rule was not satisfied (see col. 6 lines 45-64, 
throttle levels are adjusted according to a set of rules). 

As to claim 14, Wahl teaches a storage area network, comprising: 

a plurality of servers within the network, each server having an execution throttle; 
a plurality of storage controllers coupled to the network, 

each storage controller having a command queue depth, and 

each storage controller managing one or more logical storage units; wherein the 
execution throttle level of each server is set such that the execution throttle of each 
server is correlated to the command queue depth of each storage controller (see col. 3 
lines 25-50 and col. 16 lines 45-64). 
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As to claim 21, Wahl teaches a method for setting the execution throttle levels of 
a plurality of servers in a storage area network, the storage area network including a 
plurality of storage controllers, each of the storage controllers having associated 
therewith one or more logical storage units, comprising the steps of; 

identifying for each storage controller the servers that logically own each of the 
logical storage units managed by the storage controller (see col. 3 lines 25-50 and col. 
16 lines 45-64); 

summing, for each storage controller, the execution throttle levels of the servers 
that are identified as owning the logical storage units managed by the storage controller; 

determining, for each storage controller, whether the summed execution throttle 
level exceeds the command queue depth of the storage controller; and if the summed 
execution throttle level exceeds the command queue depth (see col. 3 lines 25-50 and 
col. 16 lines 45-64), 

adjusting the execution throttle level of one or more of the servers of the storage 
area network (see col. 3 lines 25-50 and col. 16 lines 45-64). 

As to claim 22, Wahl teaches a method for correlating the execution throttle 
levels of the servers of a network to the command queue depth of the storage 
controllers in the network, each of the storage controllers managing one or more logical 
storage units, comprising the steps of: 
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identifying the servers of the network; identifying the logical ownership of each 
logical storage unit of on the network; providing independent server execution throttles 
for each storage controller that is accessed by the servers (see col. 3 lines 25-50 and 
col. 16 lines 45-64); 

verifying that a rule governing the command throughput of the servers and 
storage controllers accessed by the servers is satisfied, the rule defining a relation 
between the independent execution throttle levels of the servers accessing the storage 
controllers and command queue depth of those storage controllers (see col. 3 lines 25- 
50 and col. 16 lines 45-64); 

adjusting the independent execution throttle level of at least one server in 
response to a determination that the rule was not satisfied (see col. 8 lines 20-67); 

Claim Rejections - 35 USC § 103 

The following is a quotation of 35 U.S.C. 103(a) which forms the basis for all 

obviousness rejections set forth in this Office action: 

(a) A patent may not be obtained though the invention is not identically disclosed or described as set 
forth in section 102 of this title, if the differences between the subject matter sought to be patented and 
the prior art are such that the subject matter as a whole would have been obvious at the time the 
invention was made to a person having ordinary skill in the art to which said subject matter pertains. 
Patentability shall not be negatived by the manner in which the invention was made. 

3. Claims 28, 10-13, 15-20, 23-26, 28 and 31-34 are rejected under 35 U.S.C. 

103(a) as being unpatentable over Wahl in view of Nguyen et al., U.S. Patent No. 

6,609,213 (referred to hereafter as Nguyen). 

As to claims 2 and 23, Wahl teaches a method for correlating the execution 
throttle levels of the servers of a network comprising the steps of identifying the servers 
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of the network; identifying the logical ownership of each logical storage unit on the 
network; verifying that a rule governing the command throughput of the servers and 
storage controllers of the network is satisfied, the rule defining a relation between the 
execution throttle levels of the servers of the network and command queue depth of the 
storage controllers of the network and adjusting the execution throttle level of at least 
one server of the network in response to a determination that the rule was not satisfied 
(see the rejection of claim 1 ). 

Wahl does not explicitly teach the limitation "servers having logical ownership 
over a LUN". However Nguyen teaches a method of connecting storage devices to a 
server using LUN. 

It would have been obvious for one of the ordinary skill in the art at the time of 
the invention to modify Wahl by implementing LUN between the servers and the storage 
devices because doing so would the server to distinguish between up to eight devices 
with the same SCSI ID. 

As to claims 3 and 24, Wahl teaches the method of claims 2 and 23 respectively, 
wherein the step of adjusting the execution throttle level of at least one server 
comprises the step of decrementing the execution throttle level for a selected server 
that is associated with the storage controller for which the rule was not satisfied (see 
col. 16 lines 1-25). 
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As to claims 5 and 26, Wahl teaches the method of claims 3 and 24 respectively, 
wherein the selected server is the server that has the highest execution throttle (see col. 
16 lines 1-25). 

As to claim 6, Wahl teaches the method of claim 4, wherein the selected server is 
the server that has the lowest execution throttle (see col. 16 lines 1-25). 

As to claim 7, Wahl teaches the method of claim 4, wherein the selected server is 
the server that has the highest input/output demand (see col. 16 lines 1-25). 

As to claim 8, Wahl teaches the method of claim 3, wherein the selected server is 
the server that has the lowest input/output demand (see col. 16 lines 1-25). 

As to claims 10 and 31 , Wahl teaches the method of claims 5 and 26 
respectively, further comprising the step of repeating the verifying and adjusting steps 
until the sum of the execution throttle levels for those servers having logical ownership 
over each respective storage controller does not exceed the command queue depth of 
each respective storage controller (see col. 16 lines 1-25). 

As to claims 1 1 and 32, Wahl teaches the method of claims 10 and 31 , further 
comprising the step of determining whether the execution throttle of each server 
exceeds a minimum execution throttle setting (see col. 16 lines 1-25). 

i 

As to claims 12 and 33, Wahl teaches the method of claims 1 1 and 32 
respectively, wherein the verifying and adjusting steps are automated (see col. 16 lines 
1-25). 
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As to claims 13 and 34, Wahl teaches the method of claims 12 and 33 . 
respectively, further comprising the step of setting the execution throttle level of each 
server to its maximum level prior to performing the first of the verifying and adjusting 
steps (see col. 16 lines 1-25). 

As to claim 15, Wahl teaches a method for correlating the execution throttle 
levels of the servers of a network comprising the steps of identifying the servers of the 
network; identifying the logical ownership of each logical storage unit on the network; 
verifying that a rule governing the command throughput of the servers and storage 
controllers of the network is satisfied, the rule defining a relation between the execution 
throttle levels of the servers of the network and command queue depth of the storage 
controllers of the network and adjusting the execution throttle level of at least one server 
of the network in response to a determination that the rule was not satisfied (see col. 16 
lines 1-25). 

Wahl does not explicitly teach the limitation "servers having logical ownership 
over a LUN of each respective storage controller". However Nguyen teaches a method 
of connecting storage devices to a server using LUN. 

It would have been obvious for one of the ordinary skill in the art at the time of 
the invention to modify Wahl by implementing LUN between the servers and the storage 
devices because doing so would the server to distinguish between up to eight devices 
with the same SCSI ID. 
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As to claim 16, Wahl teaches the storage area network of claim 15, wherein the 
execution throttle level of the servers may be adjusted such that the sum of the 
execution throttle level of those servers having logical ownership over a respective 
storage controller does not exceed the command queue depth of the respective storage 
controller (see col. 16 lines 1-25). 

As to claim 17, Wahl teaches the storage area network of claim 16, wherein the 
execution throttle level of the servers of the storage area network may be adjusted and 
verified repeatedly until the sum of the execution throttle level of those servers having 
logical ownership over a respective storage controller does not exceed the command 
queue depth of the respective storage controller (see col. 16 lines 1»25). 

As to claim 18, Wahl teaches the storage area network of claim 17, wherein the 
execution throttle level of each server further exceeds a minimum execution throttle 
level (see col. 16 lines 1-25). 

As to claim 19, Wahl teaches the storage area network of claim 18, wherein the 
adjustment and verification of execution throttle level is automated (see col. 16 lines 1- 
25). 

As to claim 20, Wahl teaches the storage area network of claim 19, wherein the 
execution throttle level of each server is set to its maximum level prior to adjusting or 
verifying the execution throttle levels of any of the servers of the storage area network 
(see col. 16 lines 1-25). 
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As to claim 25, Wahl teaches the method of claim 23, wherein the step of 
adjusting the execution throttle level of at least one server comprises the step of 
incrementing the execution throttle level for a selected server that is associated with the 
storage controller for which the rule was not satisfied (see col. 16 lines 1-25). 

As to claim 28, Wahl teaches the method of claim 25 wherein the selected server 
is the server that has the highest command throughput (see col. 16 lines 1-25). 
4. Claims 9 and 30 are rejected under 35 U.S.C. 103(a) as being unpatentable over 
Wahl in view of Nguyen further in view of Popat, U.S. Patent No. 5,623,672. 

Wahl teaches the method of adjusting the execution throttle level of at least one 
server comprises the step of decrementing the execution throttle level for a selected 
server that is associated with the storage controller for which the rule was not satisfied 
(see the rejection of claims 3 and 23). 

Wahl does not explicitly teach the limitation "the selected server is selected 
according to a round robin format". 

However Popat teaches a method for dynamic priority assignment to access a 
resource where the invention include round robin between groups and fixed priority 
within a group; round robin between groups and round robin within a group; and fixed 
priority. 

It would have been obvious for one of the ordinary skill in the art at the time of 
the invention to modify Wahl by implementing round robin format as taught by Popat 
because doing so would allow the system to establish request priority to each group and 
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within each group and therefore give more weight to requests received from a group 
(see Popat col. 6 lines 19-33). 

Response to Arguments 

4. Applicant's arguments have been considered but are moot in view of the new 
ground(s) of rejection. 

5. The prior art made of record and not relied upon is considered pertinent to 
applicant's disclosure. 

6. Any inquiry concerning this communication or earlier communications from the 
examiner should be directed to Hussein A El-chanti whose telephone number is 
(571 )272-3999. The examiner can normally be reached on Mon-Fri 8:30-5:00. 

If attempts to reach the examiner by telephone are unsuccessful, the examiner's 
supervisor, Ario Etienne can be reached on (571 )272-4001 . The fax phone number for 
the organization where this application or proceeding is assigned is 703-872-9306. 

Information regarding the status of an application may be obtained from the 
Patent Application Information Retrieval (PAIR) system. Status information for 
published applications may be obtained from either Private PAIR or Public PAIR. 
Status information for unpublished applications is available through Private PAIR only. 
For more information about the PAIR system, see http://pair-direct.uspto.gov. Should 
you have questions on access to the Private PAIR system, contact the Electronic 
Business Center (EBC) at 866-217-9197 (toll-free). 



Hussein Elchanti 
March 15, 2005 




